<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box {
            width: 100px;
            height: 100px;
            position: absolute;
            left: 0px;
            top: 0px;
            background: red;
        }
    </style>
</head>

<body>
    <div class="box"></div>
    <script>
        // 什么时候 开始拖动？ 鼠标按下的时候开始拖动 。
        // 1.获取 box元素
        var boxEle = document.querySelector(".box");
        boxEle.onmousedown = function (e) {
            // 准备拖动
            console.log("准备拖动");
            // A的位置：
            var AclientX = e.clientX;
            var AoffsetLeft = this.offsetLeft;

            // 按下且拖动 
            boxEle.onmousemove = function (e) {
                console.log("按下且移动");

                // 需要设置B的位置 
                var BclientX = e.clientX;

                var redLine = BclientX - AclientX + AoffsetLeft ; // 红线的距离
                boxEle.style.left = redLine + "px";
            }
        }






    </script>
</body>

</html>